הפקולטה להנדסת חשמל

# <u>תרגיל בית רטוב מספר 3</u> מערכות ספרתיות ומבנה מחשב

קראו היטב את הוראות ההגשה בסעיף 3.

נקודות יורדו למי שלא יבצע את ההוראות במדויק.

אחראית התרגיל : חוסן נטור hosen.nator@campus.technion.ac.il

שאלות בקשר לתרגיל יש להפנות לאחראי התרגיל דרך הפורום במודל. בקשות מיוחדות יש לשלוח לאחראי התרגיל במייל.

בקשות לדחייה ללא סיבה מוצדקת ידחו על הסף (ראו נוהל להגשה באיחור).

אין להגיש שום חלק מודפס – את החלק היבש יש לכתוב במעבד תמלילים (למשל: Word) ולצרף לחלק הרטוב. יש להגיש כקובץ pdf בלבד.

### 1. הנחיות כלליות



מסמן שאלות שיש לענות עליהן במסמך (החלק היבש). ניתן לענות גם באנגלית.

לצורך שרטוט מעגלים עם שערים לוגיים בתרגיל, ניתן לשרטט ידנית ולסרוק, או להשתמש בתוכנה (למשל: https://www.draw.io). את החישובים יש להקליד.

בכל מקום בו נדרש לתכנן מימוש יעיל מבחינת מספר הרכיבים, אין צורך להגן מפני hazards.



מסמן חלק שיש לבצע בסימולטור. את תוצאת הסימולציה (waveform) יש לצרף לחלק היבש ולהסביר 🦯 את התוצאות בצורה איכותית. ניתן לשמור Waveform בעזרת צילום מסך. ב-waveform יש להכיל את האותות הרלוונטיים לתרגיל (כניסות ויציאות) ובצילום להראות את הקטעים הרלוונטיים בזמן. יש לדאוג שהתמונות תהיינה ברורות. נקודות יורדו על צילומי מסך שאינם ברורים.

יש לכתוב את קוד החומרה בשפת SystemVerilog בלבד וב-syntax שנלמד בסדנאות בלבד.

במקרה של קושי בפתרון הסעיפים <u>היבשים או הרטובים,</u> יש לפנות למתרגלי הסדנאות בפורום SystemVerilog וסימולציות ב-Moodle, או בשעות הקבלה שלהם.

בכל שאלה על **דרישות התרגיל**, כלומר קשיים בהבנת דרישות הסעיפים השונים בתרגיל, יש לפנות אל או בשעת הקבלה. SystemVerilog וסימולציות ב-Moodle, או בשעת הקבלה.

> בנוסף, ניתן להיעזר במסמך בעיות ב-ModelSim וב-SystemVerilog הנמצא באתר הקורס .(ModelSim\_and\_SystemVerilog\_FAQ.pdf)

## אין צורך לצרף את הקוד לחלק היבש אלא אם נאמר אחרת.

בתרגיל זה יוצג מודל ב-SystemVerilog של מעבד RISC-V מסוג Multicycle כפי שנלמד בכיתה, אשר יורחב לתמיכה בפקודה חדשה.

## 2. הוספה של פקודת כפל למודל

בקבצי התרגיל שניתנו תוכלו למצוא מימוש של מעבד RISC-V כפי שמתואר בהרצאה 11. כמו-כן, התיקייה מכילה סביבת סימולציה למעבד. להלן רשימת הקבצים והסברים:

| File          | Description                                            |  |
|---------------|--------------------------------------------------------|--|
| rv_top.sv     | The top-level hierarchy of RISC-V                      |  |
| rv_dp.sv      | Data path section of RISC-V                            |  |
| rv_ctl.sv     | Control and state machine of RISC-V                    |  |
| rv_sim.sv     | Simulation top level                                   |  |
| params.inc    | Parameter definitions, included in SystemVerilog files |  |
| imem.hex      | Instruction memory image, read by simulation           |  |
| dmem_init.hex | Data memory initial values, read by simulation         |  |
| test.s        | Assembly code from which imem.hex is generated         |  |

המודל מממש תת-קבוצה של פקודות RISC-V. להלן רשימת הפקודות הנתמכות:

| Туре | Commands                                         |
|------|--------------------------------------------------|
| L    | LW                                               |
| S    | SW                                               |
| R    | ADD, SUB, SLL, SLT, SLTU, XOR, SRL, SRA, OR, AND |
| В    | BEQ                                              |
| J    | JAL                                              |

שימו לב כי מודל המעבד הנתון אינו מוגן מפני פקודות לא נתמכות. ברוב המקרים אם תוזן פקודה שאינה נתמכת, מכונת המצבים תעבור לפקודה הבאה מיד אחרי שלב ה-Decode. אך בחלק מהמקרים המכונה עשויה להתנהג באופן בלתי צפוי.

כאמור, המעבד הנתון בתרגיל אינו זהה לזה שנלמד בהרצאה. להלן ה-datapath ומכונת המצבים (מסוג Mealy) של המעבד בתרגיל (ניתן להשתמש ב-zoom כדי לראות את כל הפרטים):





הקבצים imem.hex ו-dmem\_init.hex, המייצגים את ה-dmem\_init.hex המייצגים את ה-dmem\_init.hex, השורה השנייה מכילה את בנויים בפורמט הבא: השורה הראשונה בקובץ מכילה את המידע שנמצא בבתים 0-3, השורה השנייה מכילה את המידע שנמצא בבתים 4-7, וכן הלאה. במידה ומופיעים פחות מ-4 בתים בשורה (כפי שניתן לראות ב-dmem\_init.hex), הבתים החסרים הם ריפוד באפסים משמאל.

לפני שאתם מתחילים בביצוע התרגיל, עברו על הקוד שקיבלתם וודאו שאתם מבינים אותו. הכניסו את קוד האסמבלי שנמצא ב-test.s לסימולטור שבאתר: http://www.kvakil.me/venus. השתמשו בכפתור ה-Dump בסימולטור לקבלת קוד מכונה, וודאו שהקוד שקיבלתם זהה לתכולה של קובץ ה-imem.hex הנתון.

הריצו את ה-test הנתון (rv\_sim) ב-ModelSim. הוסיפו לדיאגרמת הגלים את האותות המרכזיים (למשל: nr ,pc (למשל: rv\_sim). ודאו שאתם מבינים את הנצפה בדיאגרמת הגלים. (memory interface ,ALU inputs + outputs

שימו לב שקוד האסמבלי הנתון נכנס ללולאה אינסופית בסוף הריצה. כשמריצים את הסימולציה על המעבד, היא מפסיקה בשני מקרים:

- timeout קבלת
- 2. כתיבה של ערך לזיכרון המצביע על סיום הקוד (שורות הפקודה תחת finish)

בתרגיל זה יהיה עליכם להוסיף למודל המעבד תמיכה בפקודת addi המבצעת פעולת חיבור עם intermediate. שימו לב שהפקודה שתוסיפו מתנהגת באופן שונה מהפקודה addi שנלמדה בהרצאות/תרגולים. בנוסף לחישוב שימו לב שהפקודה שתוסיפו מתנהגת באופן שונה מהפקודה intermediate, היא גם מבצעת על תוצאת החיבור פעולת XOR תוצאת החיבור של 132 ביט שכולם מכילים 1). פורמט הפקודה הוא כפי שנלמד:

| imm[11:0] | rs1 | 000 | rd | 0010011 |
|-----------|-----|-----|----|---------|
|-----------|-----|-----|----|---------|

הפקודה מבצעת:

 $R[rd] = (R[rs1] + imm) ^ 0xffffffff$ 



- 2.1. הציעו מכונת מצבים חדשה עבור בקר המעבד. מכונת המצבים החדשה צריכה להיות מבוססת על מכונת המצבים הנתונה של המעבד, בתוספת המצבים הנדרשים עבור פעולת addi. שימו לב שפעולת ה-addi פעולת ה-atd צריכות להיות מחושבות בתוך ה-ALU, במחזורים נפרדים. שרטטו דיאגרמת מצבים של מכונת המצבים החדשה. סמנו עליה את המצבים החדשים שהתווספו. ציירו על גבי שרטוט של המעבד מהם השינויים שהוספתם על-מנת לתמוך בפקודה החדשה.
- של מודל המעבד. להלן רשימה חלקית של SystemVerilog- עת בצעו את השינויים הנדרשים בקוד ה-2.2 השינויים:
  - בקובץ params.inc הוסיפו את הקידוד של הפקודה החדשה.
- בקובץ rv\_ctl.sv הוסיפו למכונת המצבים הקיימת את המצבים ואת אותות הבקרה החדשים/ שינוי באותות הבקרה הקיימים.
  - בהתאם לאותות הבקרה. rv\_dp.sv הוסיפו את השינויים הדרושים ב-datapath בהתאם לאותות הבקרה.

הנחיה כללית: שימו לב כי בכל קובץ קוד שקיבלתם יש לממש module אחד בלבד. אין לממש מספר module בקובץ אחד, ואין להוסיף קבצי קוד חדשים בנוסף לאלו שקיבלתם. שימו לב כי בסעיף זה ניתן ( אם צריך) לשנות את גודל הוקטור של הכניסות והיציאות של המודולים



2.3. בקובץ test.s ב-main הוסיפו בדיקה של מימוש הפקודה החדשה.

השתמשו בפקודת lw לטעינה של ערך מזיכרון מכתובת 8. בצעו את הפקודה עם 12 (בבסיס lmm=12) דצימלי) והרגיסטר שאליו טענתם את הערך בכתובת 8, וכתבו את התוצאה לכתובת 16 בזיכרון. אין הגבלה לגבי שימוש ברגיסטרים ספציפיים בפקודות.

יצרו את קוד המכונה בעזרת הסימולטור באתר: http://www.kvakil.me/venus, והעתיקו אותו לקובץ.imem.hex

הריצו סימולציית SystemVerilog ע"י קימפול כל הקבצים בעלי סיומת sv. (ניתן לעשות זאת באמצעות SystemVerilog ע"י קימפול כל הקבצים בעלי סיומת voim rv\_sim) ואז הרצת הסימולציה (voim rv\_sim).

הוסיפו לדיאגרמת הגלים את האותות: ir ,pc ,rst ,clk וכן את אותות הבקרה. הוסיפו את הדיאגרמה לחלק היבש והסבירו אותה. שימו לב שלעתים עשויים להופיע קווים אדומים ('x') בסימולציה. בסימולציה זו, זה לא בהכרח מצביע על בעיה.

ודאו שבסוף ההרצה הקובץ dmem\_out.hex מכיל את התוצאה בכתובת הנכונה (השורה החמישית בקובץ). במידה והקובץ לא נוצר, משהו בהרצת הסימולציה היה לא תקין. הקוד שאחראי לסיום הסימולציה הוא הקוד שלכם במקום הנכון ולא הסימולציה הוא הקוד שבא עם הקובץ test.s, לכן ודאו שהוספתם את הקוד שלכם במקום הנכון ולא שיניתם את הקוד הנתון.

## <u>חלוקת הציון</u>

| Sect | Grade |
|------|-------|
| 2.1  | 20    |
| 2.2  | 50    |
| 2.3  | 30    |

| Total | 100 |
|-------|-----|

#### 3. הוראות הגשה

- ההגשה בזוגות בלבד. ניתן לחפש בני זוג דרך פורום חיפוש שותפים. הגשה ללא בן זוג ללא אישור מראש תגרור הורדה בציון של 10 נקודות.
  - יש להגיש את הקבצים הבאים (ואותם בלבד):
    - dmem init.hex
      - imem.hex •
      - params.inc
        - rv ctl.sv •
        - rv\_dp.sv •
        - rv\_sim.sv •
        - rv\_top.sv
          - test.s •
          - Dry.pdf •

- יש לארוז את כל הקבצים הנ"ל (קבצי הקוד וקובץ התשובות של החלק היבש בפורמט pdf בלבד) בקובץ יש לארוז את כל הקבצים הנ"ל (קבצי הקוד וקובץ התשובות של אחד מבני הזוג. zip אחד, בשם **cid>.zip**, כאשר
  - בתחילת קובץ התשובות לחלק היבש יש לכתוב שמות ות.ז. של כל אחד מהסטודנטים בטבלה כמו בדוגמה הבאה:

| 123456789 | שם 1 |
|-----------|------|
| 987654321 | שם 2 |

- שימו לב להגיש קובץ בפורמט zip בלבד! (לא rar, לא 2z ולא שום תוכנת כיווץ אחרת)
- אין להדפיס אף חלק בתרגיל. קובץ zip שיגיע ללא חלק יבש (קובץ pdf) יגרור ציון 0 על התרגיל כולו.
  - - עליכם לעקוב אחרי הודעות אשר מתפרסמות באתר הקורס, הודעות אלו מחייבות.
    - כל שאלה על התרגיל אשר איננה בקשה אישית צריכה להישאל דרך הפורום באתר הקורס.
- אנא בדקו היטב את הקבצים לפני ההגשה. טענות מסוג "אבל בבית זה עבד נכון" לא תתקבלנה. מומלץ לבדוק את תקינות הקוד על סביבה "נקייה" (למחוק את הספרייה work, ליצור אותה מחדש ולקמפל לתוכה מחדש את כל קבצי הקוד).
  - קוד שלא מתקמפל יגרור הורדת נקודות מלאה של הסעיף.
  - שימו לב ל-Warnings שמתקבלים כפלט של הסימולטור. אזהרות יכולות להופיע גם בשלב הvlog וגם בשלב ה-vsim. נקודות יורדו על Varnings חמורים.
- הגשה באיחור ללא אישור: על כל יום איחור יורדו 5 נקודות. הגשות באיחור מותרות עד שבוע מתאריך ההגשה.

#### 4. המלצות לתרגיל:

- .Notepad++ מומלץ לערוך את קבצי הקוד בתוכנת
- לפני שאתם ניגשים לכתוב את הקוד שלו. ככל שתקדישו יותר זמן לתכנון module 4.2 מוקדם, כך שלב המימוש יהיה קל יותר.
  - 4.3. אל תחכו לרגע האחרון. בד"כ שלב ה-debug ארוך ומסובך יותר משלב כתיבת הקוד.